কিউ এর ধারণা এবং অপারেশন: Enqueue, Dequeue, Front, Rear

স্ট্যাক এবং কিউ (Stack and Queue) - ডাটা স্ট্রাকচার & অ্যালগরিদম (Data Structure & Algorithms) - Computer Science

353

কিউ (Queue) হল একটি গুরুত্বপূর্ণ ডেটা স্ট্রাকচার যা FIFO (First In, First Out) পদ্ধতির ভিত্তিতে কাজ করে। এর মানে হলো যে উপাদানটি প্রথমে কিউতে যোগ করা হয়, সেটি প্রথমে বের হবে। কিউ সাধারণত দৈনিক জীবনে ব্যবহৃত অনেক সিস্টেমে দেখা যায়, যেমন সার্ভিস ডেস্কে, প্রিন্টার ম্যানেজমেন্টে এবং আরও অনেক ক্ষেত্রে।

কিউয়ের মৌলিক ধারণা

কিউ একটি আবদ্ধ ডেটা স্ট্রাকচার, যা দুটি প্রধান অপারেশন ব্যবহার করে: Enqueue এবং Dequeue। এছাড়াও, কিউয়ের শীর্ষ এবং তল অর্থাৎ প্রথম এবং শেষ উপাদান সংক্রান্ত কিছু অপারেশন থাকে।

কিউয়ের অপারেশন

১. Enqueue:

  • নতুন উপাদান কিউতে যোগ করার প্রক্রিয়া। এটি কিউয়ের শেষে নতুন উপাদান যুক্ত করে।
  • টাইপ: O(1) সময় জটিলতা।

২. Dequeue:

  • কিউ থেকে প্রথম উপাদান মুছে ফেলার প্রক্রিয়া। এটি কিউয়ের শুরু থেকে উপাদানটি বের করে এবং মুছে দেয়।
  • টাইপ: O(1) সময় জটিলতা।

৩. Front:

  • কিউয়ের প্রথম উপাদানটি দেখতে পাওয়ার প্রক্রিয়া। এটি কেবল প্রথম উপাদানটি রিটার্ন করে কিন্তু এটি মুছে দেয় না।
  • টাইপ: O(1) সময় জটিলতা।

৪. Rear:

  • কিউয়ের শেষ উপাদানটি দেখতে পাওয়ার প্রক্রিয়া। এটি কেবল শেষ উপাদানটি রিটার্ন করে কিন্তু এটি মুছে দেয় না।
  • টাইপ: O(1) সময় জটিলতা।

উদাহরণ: কিউ ব্যবহার

এখন একটি সম্পূর্ণ উদাহরণ দিয়ে কিউয়ের অপারেশনগুলো বোঝা যাক:

from collections import deque

class Queue:
    def __init__(self):
        self.queue = deque()

    def enqueue(self, item):
        self.queue.append(item)  # Enqueue

    def dequeue(self):
        if not self.is_empty():
            return self.queue.popleft()  # Dequeue
        return None

    def front(self):
        if not self.is_empty():
            return self.queue[0]  # Front
        return None

    def rear(self):
        if not self.is_empty():
            return self.queue[-1]  # Rear
        return None

    def is_empty(self):
        return len(self.queue) == 0

    def size(self):
        return len(self.queue)

# ব্যবহার
my_queue = Queue()
my_queue.enqueue(10)
my_queue.enqueue(20)
my_queue.enqueue(30)

print("Front element:", my_queue.front())  # 10
print("Rear element:", my_queue.rear())    # 30

print("Dequeue element:", my_queue.dequeue())  # 10
print("New front element:", my_queue.front())  # 20
print("Queue size:", my_queue.size())          # 2

উপসংহার

কিউ একটি গুরুত্বপূর্ণ ডেটা স্ট্রাকচার যা FIFO পদ্ধতির উপর কাজ করে। এর বিভিন্ন অপারেশন যেমন Enqueue, Dequeue, Front, এবং Rear ডেটা ব্যবস্থাপনায় কার্যকরী ভূমিকা পালন করে। কিউ ব্যবহৃত হয় বিভিন্ন বাস্তব জগতের সমস্যা সমাধানে, যেমন সার্ভিস ডিস্ক, প্রিন্টার ম্যানেজমেন্ট, এবং অনেক অ্যাপ্লিকেশনে।

Promotion

Are you sure to start over?

Loading...